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SPECIFICATION 



To all whom it may concern: 

Be It Known, That I, Donald F. Hemminger, a citizen of United States of 
America, residing at Beavercreek, OH, have invented certain new and useful 
improvements in SYNCHRONIZED WEB SCROLLING, of which I declare the 
following to be a full, clear and exact description: 
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SYNCHRONIZED WEB SCROLLING 

The invention concerns synchronization of scrolling through documents in 
multiple computers, particularly when those computers contain copies of a single 
document, which was retrieved from a single source, such as a web site. 



BACKGROUND OF THE INVENTION 

"Synchronized browsing" represents one type of video conferencing. In 
synchronized browsing, multiple parties, at different computers, view a common 

1 0 image, such as a single web page. The web page originates from a remote server, 
which distributed the web page to the parties through a public-access, packet- 
switched network, such as the Internet. 

When one party, such as the leader of the conference, navigates through the 
page, different images will appear on the leader's computer. This navigation process 

15 is caused by commands which the leader issues to the leader's computer. The 

synchronized browsing system distributes these commands to the computers of the 
other parties, which then execute the same commands. These commands may be 
executed exclusively by the computers in question, or they may entail issuance of 
commands to the server, to attain additional data packets. 

2 0 Under this process, all parties continually view the same, common, image as 

contained on the leader's computer, even as that image changes. 



OBJECTS OF THE INVENTION 

An object of the invention is to provide improved 
2 5 internet-based collaboration. 



SUMMARY OF THE INVENTION 

In one form of the invention, a host computer, which is a member of a group 
of computers, scrolls through a document. When the scrolling terminates, the host 
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computer sends a message to the other computers indicating the part of the document 
which the host computer is displaying. The other computers then also display that 
part which the host displays. 



5 BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 illustrates computers interconnected by a packet-switched network, 
such as the Internet. 

Figures 2 and 3 illustrate steps used by one form of the invention. 
Figure 4 illustrates two simultaneous data linkages used by the invention: a 
1 0 telephone conference and a network link. 

Figure 5 illustrates navigation through a sequence of windows. 
Figure 6 is a flow chart representing the navigation of Figure 5. 
Figure 7 illustrates scrolling. 

Figure 8 illustrates one conception of a large document, such as a web page, 
1 5 and also a conception of the meaning of scrolling. 

Figure 9 is a flow chart illustrating logic implemented by one form of the 
invention. 



DETAILED DESCRIPTION OF THE INVENTION 

2 0 Figure 1 illustrates three participants, A through C, who are connected to a 

public-access, packet-switched network 3, such as the INTERNET, as indicated. 

Figure 1 also shows a SERVER, which is also linked to the network 3. 

Two features of packet-switched networks are important. One is that 

messages are transmitted in the form of "packets," which are collections of binary 
2 5 data. For example, if the SERVER is to transmit a large document to the computer 

of a participant, the SERVER will package the document into several packets, and 

transmit them to the participant's computer. 

A second feature is that, when parties transmit packets to each other, no direct 

connection (in general) exists between the parties. Rather, the sending party places 
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the address of the receiving party onto the packet and delivers the packet to one of 
the member-computers of the network. That member relays the packet to another 
member, and the relay process continues until the packet reaches the receiving party. 
For example, when participant A sends a packet to participant B, the packet may 
5 follow the route indicated by dashed arrow 6. The vertices of the hexagons 9 
represent the member-computers, which pass the packet along. 

These two features allow communication to occur between a very large 
number of pairs of parties. In fact, the number of pairs of parties communicating can 
exceed the total number of possible party-party connections within the network, 

1 0 because the connections are, in effect, shared by the parties. 

These two features also allow individual parties to obtain access to "web 
pages.' 1 For example, a SERVER 9 may store multiple different web pages, each of 
which consists of a collection of data, and is managed by its own respective owner, 
or manager. Participant A may transmit a request for a page to SERVER 9, by 

1 5 delivering a request-packet to the network which is addressed to SERVER 9. (In 
practice, Participant A would probably utilize an Internet Access Provider to deliver 
the request packet, in order to eliminate any requirement on Participant As part to 
deal with the protocols required by the network.) The network delivers the request- 
packet to SERVER 9. 

2 0 When SERVER 9 receives the request-packet, it analyzes the message 

contained therein, identifies the particular web page which is sought, and then 
transmits the web page, in the form of packets, to Participant A, who requested the 
page. 

If the web page is large, it may be broken into multiple groups of packets, not 
2 5 all of which are initially transmitted to Participant A. Instead, the SERVER 9 would 
deliver an initial group of packets to Participant A, and then deliver other groups of 
packets, as requested. 

Synchronized browsing processes represent a refinement to this type of 
packet distribution, and will now be explained by way of a simplified example. 
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First, as indicated in Figure 2, all participants who wish to hold a conference perform 
the appropriate log-in procedures to a common web page stored by SERVER 9. The 
participants may receive the address of the web page from a common source, such as 
from participant A, who initiates the conference, as indicated in Figure 3. 
5 In addition, and in parallel with the conference, the parties initiate a standard 

multi-party telephone conference, using the public telephone system, or other 
communication medium, as indicated in Figure 4. At this time, two events are now 
occurring: (1) all participants are connected with each other through the telephone 
conference, and (2) all participants view the initial screen of the common web page, 

1 0 which was transmitted to their computers by the SERVER 9. This image is 
indicated by screen 12 in Figure 5. 

Many web pages contain multiple computer screens, and allow users to 
navigate among the screens. For example, screen 12 in Figure 5 is shown as 
containing buttons 15, 18, and 21. Actuating button 15, by a pointing device, causes 

1 5 screen 24 to be displayed. Actuating button 1 8 causes screen 27 to be displayed. 

Screen 27 may contain its own buttons, such as button 30, which causes 
further screens to be displayed, such as screen 33. 

In the general case, the situation can be represented by a flow chart, as in 
Figure 6. An initial screen SI allows access to multiple successor screens, shown as 

2 0 two successors S2 and S3. Those screens lead to their own successors, as indicted. 
In addition, a given screen, such as screen SA, may be reachable through multiple 
routes, as indicated by arrows 40 and 44, so that successors do not necessarily 
possess unique ancestors. 

Synchronized browsing allows Participant A in Figure 2, who is designated 

25 as the "host," to navigate through a sequence of screens. While the host navigates, 
synchronized browsing causes the displays D of the other computers to display the 
same screens as Participant A's computer. Thus, under synchronized browsing, all 
computers display the same screen, in synchrony. 
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The invention enhances synchronized browsing, and may be used in 
conjunction with synchronized browsing systems. Alternately, the invention may be 
used on a stand-alone basis. 

Figure 7 illustrates the appearance of the display DA of the host, namely, 
5 Participant A in Figure 2, but at different times. For example, at one time, the 

display DA may display a FIRST SCREEN, as indicated. At other times, the display 
DA may display a MIDDLE SCREEN or a LAST SCREEN. 

Participant A controls which screen is displayed through an "elevator bar ,f 
EB, indicated by the large arrows Al - A3, through a process called "scrolling." 
1 0 When the elevator bar EB is located at the highest position, as indicated by arrow 
Al, it causes the FIRST SCREEN to be displayed. When the elevator bar EB is 
located at a medial position, as indicated by arrow A2, it causes a MIDDLE 
SCREEN to be displayed. When the elevator bar EB is located at the lowest 
position, as indicated by arrow A3, it causes the LAST SCREEN to be displayed. 
15 As Figure 8 shows, the web page can be viewed as a long document 50. It is 

(conceptually) divided into screens, as indicated. The correspondence between the 
elevator bar EB and three of the screens is illustrated. 

The elevator bar is manipulated by a pointing device (not shown), such as a 
mouse. The mouse communicates with the operating system (not shown) within the 
2 0 computer of Participant A in Figure 2, through messages. Through the messages, 
the operating system ascertains when the mouse-cursor (not shown) is positioned 
over the elevator bar EB in Figure 7, and when the mouse itself indicates that the bar 
EB is to be moved. (The latter indications are issued through buttons on the mouse.) 
When those messages are detected, the operating system scrolls through the 
2 5 document 50 in Figure 8, displaying the screen indicated by the elevator bar EB. (Of 
course, this operation is not limited to full screens. Part of one screen, and part of a 
subsequent screen, may be displayed.) 

One type of operating system which provides this type of operation is that 
sold under the name Windows, available from Microsoft Corporation, Redmond, 
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Washington. Programming this operating system is described in the book 
Programming Windows , by Charles Petzold (Microsoft Press). 

The invention is overlaid onto the operating system. The invention intercepts 
mouse messages, and, in effect, distributes selected mouse messages, namely, those 
5 causing scrolling, to the other computers. Although all scrolling messages could be 
distributed to the other computers, thereby causing all computers to behave 
identically, a different approach is preferred. Figure 9 is a flow chart illustrating the 
preferred procedure. 

Figure 9 illustrates logic which is interconnected into the mouse-processing 

1 0 routines of the operating system. Block 75 indicates that the invention intercepts 
mouse messages. Decision block 80 indicates that these messages are examined, 
and inquiry is made whether the messages request scrolling. If not, the NO branch is 
taken, and the mouse-processing routines continue in the normal manner, as 
indicated by block 85. 

15 If the mouse messages do call for scrolling, then the YES branch is taken 

from block 80. Block 90 indicates that the invention waits for scrolling to terminate. 
For example, scrolling may be executed by the following sequence of events: (1) 
placing the mouse-cursor (not shown) over the elevator bar EB in Figure 7, (2) 
actuating a button on the mouse itself (not shown), (3) physically moving the mouse, 

2 0 thereby causing the cursor to move, thereby "dragging" the elevator bar EB, and (4) 
releasing the mouse button. 

When the last event occurs, namely, releasing the mouse button, the scrolling 
terminates. In this example, the invention would detect the mouse-message 
generated by that event, and, based on that event, would conclude that scrolling has 

2 5 terminated, as indicated in block 90. 

At this time, block 95 is reached. That block transmits the coordinates of the 
elevator bar EB in Figure 7 to the other computers. The term "coordinates" refers to 
the relative position of the elevator bar EB in Figure 8, or an equivalent measure of 
position within the document 50 in Figure 8. For example, the elevator bar EB can 
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be viewed as travelling along a one-foot ruler. When located at zero inches, its 
position, in percentage points, is zero. When located at the six-inch mark, its 
position is 50 percent. When located at the twelve-inch mark, its position is 100 
percent. 

5 When the participants' computers receive the coordinates, they display the 

screen (or combination of partial screens) indicated by the coordinates. Specifically, 
if the host's display initially shows screen 1 in Figure 8, and the host then scrolls to 
screen 4, after screen 4 is reached, the invention infers the arrival at screen 4, and 
then broadcasts the coordinates of the final screen, screen 4, to all the participants 1 
10 computers. They then jump to screen 4. 

Additional Considerations 

1. A distinction should be drawn between "scrolling" and "navigating." The 
former refers to scanning through document 50 in Figure 8. By analogy, a movie 

1 5 film is "scrolled" when it runs through a motion picture projector. 

During slow scrolling, all parts of document 50 will be visible. However, it is 
possible that, during rapid scrolling, parts of the document 50 may not be visible. 
For example, if the elevator bar EB is moved rapidly, the scan may occur so fast that 
parts of the underlying document may not appear. 

2 0 This fact illustrates one characteristic of scrolling: when motion of the 

elevator bar EB terminates, part of the document will then be displayed. The 
displayed part is derived from the single screen's worth of the document 50 which 
brackets the elevator bar EB in some pre-defined manner. For example, the 
bracketing may span from one-half a screen's worth above the bar EB to one-half a 

2 5 screen's worth below the bar EB. In a sense, a miniature screen MS in Figure 8 can 
be conceived as following the elevator bar EB. That part of the document contained 
within the miniature screen MS is displayed on the computer. 

In contrast, "navigating" refers to jumping from screen-to-screen, as by 
moving along the flow chart of Figure 6. In navigating, no elevator bar is used, so 
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that no cessation of motion of the elevator bar occurs and, consequently, the 
cessation causes no part of a document to appear. 

In one form of the invention, one computer scrolls, and, when scrolling 
terminates, the other computers immediately navigate to the same position in the 
5 document. For example, the display of the host in Figure 2 may be scrolled. Upon 
termination of the scrolling, the computers of the other participants navigate to the 
corresponding position within the web page, and display the same part of the page 
which the host displays. But the other participants do not display the intervening 
parts, which the host would have displayed, if the host scrolled sufficiently slowly. 

10 

2. The transmission of the coordinates indicated in block 95 in Figure 9 
occurs by way of transmission of data packets, through the packet-switched network, 
to the computers of the other participants. Because of this, all participants in the 
conference must be in possession of an appropriate address, such as a URL 

1 5 (Universal Resource Locator), to guide the packets. Restated, the ordinary person, 
operating a computer at home, does not own the appropriate address, such as a URL, 
and cannot participate in the synchronized scrolling described herein. 

3. The invention should be distinguished from other types of video 

2 0 conferencing systems. Figure 4 shows two simultaneous communication links: (1) a 
standard telephone conference and (2) a network connection, although the latter, as 
explained above, is not maintained continuously. Both of these links can be of the 
low-bandwidth type, each having a bandwidth equivalent to a POTS (Plain Old 
Telephone Service) telephone channel, which is about 3500 Hz. Other types of 

2 5 video conferencing systems require high-bandwidth communication links, and many 
of these systems perform poorly with low-bandwidth links. 

4. Apparatus which accomplishes the functions described above, and 
outlined in the flow chart of Figure 9, is represented by block 1 10 in the host's 
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computer in Figure 2, as well as blocks 1 15 in the other computers. The latter blocks 
perform the navigation described above, when they receive the coordinates of block 
95 in Figure 9. 

5 5. The invention provides particular usefulness in the context of video 

conferencing and remote collaboration systems. Presently available systems may be 
classified into three types: 

(1) Full-featured video conferencing systems, which provide, for example, 
white-boarding, application-sharing, and full sharing of screens and cursors. 

1 0 However, these systems perform poorly when used with ordinary POTS telephone 
channels, operating at 28.8 Kilo-bits per second. 

(2) General-purpose messaging and chatting programs. However, these do 
not provide significant meeting support, nor synchronized browsing. 

(3) Simple tools in which common URLs (Uniform Resource 
1 5 Locators) are shared. The URLs act as addresses for the locations on the 

INTERNET where web pages can be found. Sharing the URLs allows the parties 
involved to view a common web page. However, in these tools, no person leads the 
other parties through a web page, or sequence of web pages: there is no 
synchronized scrolling. 
2 0 Simply stated: these tools do not optimally support multi-party conferences 

utilizing low-bandwidth telephone channels. 

An alternative approach to holding a multi-party conference without such 
tools is to distribute, in advance, paper documents to all participants. Then, utilizing 
a common telephone conference, one party leads the conference participants through 
2 5 the documents. 

This approach, while appealing in theory, presents the practical problem that 
some conference participants are found to inevitably lose their places within the 
documents, and consequently must interrupt other participants (who are not, in 
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general, located at the same site) in order to ascertain the current position within the 
documents. 

For example, assume that a participant is reading a document, in synchrony 
with the leader of the conference. That participant may be interrupted by an 
5 associate. The participant's natural tendency is to place the document aside, without 
marking the current place, and give full attention to the associate. Later, the 
associate departs, and the participant wishes to re-join the conference. However, the 
participant does not know the leader's current position within the documents. That is 
true even if the participant had marked the place-of-interruption. 

1 0 The invention provides a system which mitigates, or eliminates, many of the 

features of the systems just described. The invention emphasizes multi-party 
conferencing, handling conferences between at least two participants, and among as 
many as 75 participants, or more. In the general case, the participants are located at 
various different locations. 

15 In addition to being useful in facilitating remote conferences, the invention is 

also useful in (1) Internet-based education, wherein a teacher leads a class of 
students, all located at different locations, and (2) a kickoff among sales 
professionals, in the introduction of a new product. 

Under the invention, the conference is organized in a peer-to-peer format, 

2 0 over the Internet. That is, no distinct server is required, although one of the 

participating computers is designated as a Host, and coordinates the browsing as 
discussed in the Detailed Description of the Invention above. 

In addition to the Host, two other designations are made: Guest and Scribe. 
A Guest is a conference participant; multiple Guests are involved in a multi-party 

2 5 conference. Also, the Host may temporarily appoint a Guest as Host, who then acts 
as a temporary leader. The Scribe keeps a record of the conference. 

In addition to the Internet connection, all parties are connected in a normal 
POTS telephone conference. The Internet connection is independent of this 
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telephone conference, and the invention does not control, or interfere with, that 
conference, except possibly to record it. 

The Internet communications are undertaken using industry-standard Internet 
protocols and commands, which, of course, can be expected to change over time, 
5 and further change as new Internet-type networks become available. 

As the Host navigates, travelling from web page to web page, and through 
individual web pages themselves, messages are sent to all participants informing 
them of the navigation, and allowing them to download the same web pages as the 
Host, and to move to the same locations within those web pages as the Host. 
1 0 Consequently, all participants view the same image, and that image follows the 
Host's image. 

The Host is informed of the progress of each participant, so that no 
participant is left behind. 

As stated above, the Host can appoint a Guest as Host. Several modes of 

1 5 operation are possible in this connection. In one, the Host makes a simple 
appointment, in effect, passing a baton. In another mode, a queue of Guests is 
established, wherein each is given an allotted time, or an allotted amount of web 
space to cover. When each Guest-Host finishes, the next Guest-Host is 
automatically appointed. 

20 In the latter mode, the queue can be established in at least two ways. One, the 

Host can create the queue, by listing Guests. Two, the Guests can petition the Host 
for Host-appointments, and the Host lists the petitioning Guests in the queue. 

All activities of the meeting are recorded by the Scribe. This recording may 
include a recording of the POTS telephone conversation. That recording may be 

2 5 digitized, and stored in a common location, and made available for downloading 
through the Internet. 
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Numerous substitutions and modifications can be undertaken without 
departing from the true spirit and scope of the invention. What is desired to be 
secured by Letters Patent is the invention as defined in the following claims. 
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CLAIMS 

1 . In a conference among multiple computers which are operated by 
participants, the improvement comprising the following steps: 

5 a) detecting, in one computer, the occurrence of scrolling through a 

document; 

b) when said scrolling terminates, ascertaining which part of the document is 
being displayed by said computer; and 

c) after said ascertainment, transmitting to other computers data which 
1 0 enables them to display said part of the document. 

2. Improvement according to claim 1, wherein the data consists essentially of 
a location of a group of data within the document, 

15 3 . Improvement according to claim 1 , wherein the data enables the other 

computers to navigate to said part of the document, without scrolling. 

4. Improvement according to claim 1, wherein all computers are linked by a 
packet-switched network, and the data is transmitted along said network. 

20 

5. Improvement according to claim 1, and further comprising the step of 

d) maintaining a telephone conference among the participants. 

6. In a conference among multiple computers which are operated by 
2 5 participants, the improvement comprising the following steps: 

a) detecting, in one computer, the occurrence of scrolling through a 
document, wherein parts of the document are sequentially displayed on a screen; 

b) when said scrolling terminates, ascertaining a coordinate within the 
document which is contained within the part of the document being displayed; and 



13 



NCR Docket No. 7941 



c) transmitting a data packet to a packet-switched network for delivery to 
other of the multiple computers. 

7. An apparatus, comprising: 

5 a) a computer-readable storage medium; 

b) software means, physically configured in the storage medium, for: 

i) detecting when scrolling through a document occurs in a computer; 

ii) detecting when said scrolling terminates, and, upon termination, 
ascertaining which part of the document is being displayed by said computer; and 

1 0 iii) transmitting to other computers a coordinate which enables them to 

display said part of the document. 

8. A method of operating a group of computers, comprising the following 

steps: 

15 a) loading a common document into the computers; 

b) detecting scrolling at a first computer, which causes a displayed image to 
scroll from a first position within the document, through intermediate positions 
within the document, to a final position within a document; and 

b) transmitting information to other computers which are currently 
2 0 displaying the first position of the document, which causes the other computers to 
display said final position within the document, without displaying intermediate 
positions. 

9. Method according to claim 8, wherein the document is loaded from a 
2 5 common web site, from a packet-switched, public-access network. 

10. Method according to claim 8, wherein the information of paragraph (b) is 
transmitted to the other computers through a packet-switched, public-access 
network. 
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ABSTRACT OF THE DISCLOSURE 

A video conferencing system. In a type of conferencing known as 
"synchronized browsing," several computers download a common web page from a 
public-access, packet-switched network, such as the Internet. Software in a first 
5 computer informs the other computers how the first computer is navigating through 
the web page, and sends the other computers data which enables them to navigate 
the same path, so that all computers navigate in synchrony, and display the same 
sequence of images. Under the invention, while such a web page is being navigated 
by such computers, software observes one of them, and looks for the event of 
1 0 scrolling (as opposed to navigation). When scrolling is detected, its termination is 
awaited. When termination occurs, the invention tells the other computers which 
part of the page is currently being displayed, so that the others can navigate to that 
part and also display it. 
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hereby expressly waive my right to revoke the Power of Attorney granted above. 
Address all telephone calls to James M. Stover at telephone number 937/445-7663. 
Address all correspondence to James M. Stover, Intellectual Property Section, Law 
Department, NCR Corporation, 101 West Schantz, ECD-2, Dayton, Ohio 45479-0001. 

I hereby declare that all statements made herein of my own knowledge are true and that 
all statements made on information and belief are believed to be true; and further that 
these statements were made with the knowledge that willful false statements and the like 
so made are punishable by fine or imprisonment, or both, under §1001 of Title 18 of the 
United States Code and that such willful false statements may jeopardize the validity of 
the application or any patent issued thereon. 



Full name of sol^^nventQr 
Inventor's signature _ 

Residence 3697 McElrath Pike, Beavercreek, OH 
Citizenship United States of America 




Post Office Address Same as above 
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